← module\_shift (/wiki/module\_shift)

This exercise is an extension of module\_shift (/wiki/module\_shift). Instead of module ports being only single pins, we now have modules with vectors as ports, to which you will attach wire vectors instead of plain wires. Like everywhere else in Verilog, the vector length of the port does not have to match the wire connecting to it, but this will cause zero-padding or trucation of the vector. This exercise does not use connections with mismatched vector lengths.

You are given a module my\_dff8 with two inputs and one output (that implements a set of 8 D flip-flops). Instantiate three of them, then chain them together to make a 8-bit wide shift register of length 3. In addition, create a 4-to-1 multiplexer (not provided) that chooses what to output depending on sel[1:0]: The value at the input d, after the first, after the second, or after the third D flip-flop. (Essentially, sel selects how many cycles to delay the input, from zero to three clock cycles.)

The module provided to you is: module  $my_dff8$  ( input clk, input [7:0] d, output [7:0] q );

The multiplexer is not provided. One possible way to write one is inside an always block with a case statement inside. (See also: mux9to1vO (/wiki/mux9to1v))



## **Module Declaration**

```
module top_module (
    input clk,
    input [7:0] d,
    input [1:0] sel,
    output [7:0] q
);
```

## 

```
Solution
                                                                        Show solution
    module top_module (
  2
        input clk,
  3
        input [7:0] d,
        input [1:0] sel,
  4
        output reg [7:0] q
  5
  6);
  7
        wire [7:0] o1, o2, o3;  // output of each my_dff8
  8
  9
 10
        // Instantiate three my_dff8s
        my_dff8 d1 ( clk, d, o1 );
 11
 12
        my_dff8 d2 ( clk, o1, o2 );
        my_dff8 d3 ( clk, o2, o3 );
 13
 14
 15
        // This is one way to make a 4-to-1 multiplexer
        always @(*)
                       // Combinational always block
 16
 17
            case(sel)
                 2'h0: q = d;
 18
 19
                 2'h1: q = o1;
 20
                 2'h2: q = o2;
 21
                 2'h3: q = o3;
 22
            endcase
 23
 24 endmodule
 25
```

Retrieved from "http://hdlbits.01xz.net/mw/index.php?title=Module\_shift8&oldid=1448 (http://hdlbits.01xz.net/mw/index.php?title=Module\_shift8&oldid=1448)"

Category (/wiki/Special:Categories): Modules (/wiki/Category:Modules)

## **Problem Set Contents**

- Getting Started
- **▼ Verilog Language** 
  - ▶ Basics
  - Vectors
  - **▼** Modules: Hierarchy

    - ◆ Connecting ports by position (/wiki/module\_pos)
    - Connecting ports by name (/wiki/module\_name)
    - ◆ Three modules (/wiki/module\_shift)

    - ◆ Adder 1 (/wiki/module\_add)
    - Adder 2 (/wiki/module\_fadd)
    - O Carry-select adder (/wiki/module\_cseladd)
    - O Adder-subtractor (/wiki/module\_addsub)
  - ▶ Procedures
  - ▶ More Verilog Features
- ▶ Circuits
- ▶ Verification: Reading Simulations
- Verification: Writing Testbenches